<template>
  <div class="user-container">
    <!-- 用户基本信息面板 -->
    <div class="user-card">
      <!-- 用户头像、姓名 -->
      <van-cell>
        <!-- 使用 title 插槽来自定义标题 -->
        <template #icon>
          <img :src="user.photo" alt="" class="avatar">
        </template>
        <template #title>
          <span class="username">{{ user.name }}</span>
        </template>
        <template #label>
          <van-tag color="#fff" text-color="#007bff">已认证</van-tag>
        </template>
      </van-cell>
      <!-- 动态、关注、粉丝 -->
      <div class="user-data">
        <div class="user-data-item">
          <span>{{ user.art_count }}</span>
          <span>动态</span>
        </div>
        <div class="user-data-item">
          <span>{{ user.follow_count }}</span>
          <span>关注</span>
        </div>
        <div class="user-data-item">
          <span>{{ user.fans_count }}</span>
          <span>粉丝</span>
        </div>
      </div>
    </div>

      <!-- 操作面板 -->
      <van-cell-group class="action-card">
        <van-cell icon="edit" title="编辑资料" is-link to="/user_editor" />
        <van-cell icon="chat-o" title="小思同学" is-link to="/chat" />
        <van-cell icon="warning-o" title="退出登录" is-link @click="quitFn"/>
      </van-cell-group>
  </div>
</template>
<script>
import { userInfoAPI } from '@/api'
import { Dialog } from 'vant'
import { removeToken } from '@/utils/token'
export default {
  data () {
    return {
      user: {}
    }
  },
  methods: {
    // 退出登录方法
    async  quitFn () {
      try {
        const result = await Dialog.confirm({
          title: '是否退出登录'
        })
        if (result === 'confirm') {
          removeToken()
          this.$router.replace('/login')
        }
      } catch (err) {

      }
    }
  },
  components: {
    [Dialog.Component.name]: Dialog.Component
  },
  // 获取用户信息
  async activated () {
    const res = await userInfoAPI()
    this.user = res.data.data
    this.$store.commit('SET_USERPHOTO', this.user.photo)
  }
}
</script>

<style scoped lang="less">
  .user-container {
    .user-card {
      background-color: #007bff;
      color: white;
      padding-top: 20px;

      .van-cell {
        background: #007bff;
        color: white;

        &::after {
          display: none;
        }

        .avatar {
          width: 60px;
          height: 60px;
          background-color: #fff;
          border-radius: 50%;
          margin-right: 10px;
        }

        .username {
          font-size: 14px;
          font-weight: bold;
        }
      }
    }

    .user-data {
      display: flex;
      justify-content: space-evenly;
      align-items: center;
      font-size: 14px;
      padding: 30px 0;

      .user-data-item {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        width: 33.33%;
      }
    }
  }
</style>
